Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@wordpress/compose
Advanced tools
@wordpress/compose is a utility library for composing higher-order components (HOCs) in React. It provides a set of functions that help in managing component state, lifecycle, and other common patterns in a more declarative and functional way.
withState
The `withState` HOC is used to add state to a functional component. In this example, `count` is the state variable and `setCount` is the function to update it.
const { withState } = require('@wordpress/compose');
const MyComponent = ({ count, setCount }) => (
<div>
<p>{count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
const EnhancedComponent = withState('count', 'setCount', 0)(MyComponent);
withInstanceId
The `withInstanceId` HOC provides a unique instance ID to each instance of the component. This can be useful for accessibility or for differentiating between multiple instances of the same component.
const { withInstanceId } = require('@wordpress/compose');
const MyComponent = ({ instanceId }) => (
<div>
<p>Instance ID: {instanceId}</p>
</div>
);
const EnhancedComponent = withInstanceId(MyComponent);
compose
The `compose` function is used to combine multiple HOCs into a single HOC. In this example, `withState` and `withInstanceId` are combined to enhance `MyComponent`.
const { compose, withState, withInstanceId } = require('@wordpress/compose');
const MyComponent = ({ count, setCount, instanceId }) => (
<div>
<p>Instance ID: {instanceId}</p>
<p>{count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
const EnhancedComponent = compose(
withState('count', 'setCount', 0),
withInstanceId
)(MyComponent);
Recompose is a React utility belt for function components and higher-order components. It provides a similar set of utilities for managing state, lifecycle, and other common patterns in a more functional way. Compared to @wordpress/compose, Recompose offers a broader range of utilities and is more widely used in the React community.
Redux is a state management library for JavaScript applications. While it is not specifically for composing higher-order components, it provides a way to manage application state in a predictable way. Compared to @wordpress/compose, Redux is more focused on global state management rather than enhancing individual components.
React-Redux is the official React binding for Redux. It provides HOCs like `connect` to connect React components to the Redux store. Compared to @wordpress/compose, React-Redux is specifically designed for integrating Redux with React components.
The compose
package is a collection of handy Hooks and Higher Order Components (HOCs) you can use to wrap your WordPress components and provide some basic features like: state, instance id, pure...
The compose
function is an alias to flowRight from Lodash. It comes from functional programming, and allows you to compose any number of functions. You might also think of this as layering functions; compose
will execute the last function first, then sequentially move back through the previous functions passing the result of each function upward.
An example that illustrates it for two functions:
const compose = ( f, g ) => x
=> f( g( x ) );
Here's a simplified example of compose in use from Gutenberg's PluginSidebar
component:
Using compose:
const applyWithSelect = withSelect( ( select, ownProps ) => {
return doSomething( select, ownProps );
} );
const applyWithDispatch = withDispatch( ( dispatch, ownProps ) => {
return doSomethingElse( dispatch, ownProps );
} );
export default compose(
withPluginContext,
applyWithSelect,
applyWithDispatch
)( PluginSidebarMoreMenuItem );
Without compose
, the code would look like this:
const applyWithSelect = withSelect( ( select, ownProps ) => {
return doSomething( select, ownProps );
} );
const applyWithDispatch = withDispatch( ( dispatch, ownProps ) => {
return doSomethingElse( dispatch, ownProps );
} );
export default withPluginContext(
applyWithSelect( applyWithDispatch( PluginSidebarMoreMenuItem ) )
);
Install the module
npm install @wordpress/compose --save
This package assumes that your code will run in an ES2015+ environment. If you're using an environment that has limited or no support for ES2015+ such as lower versions of IE then using core-js or @babel/polyfill will add support for these methods. Learn more about it in Babel docs.
For more details, you can refer to each Higher Order Component's README file. Available components are located here.
# compose
Composes multiple higher-order components into a single higher-order component. Performs right-to-left function composition, where each successive invocation is supplied the return value of the previous.
Parameters
...Function
: The HOC functions to invoke.Returns
Function
: Returns the new composite function.# createHigherOrderComponent
Given a function mapping a component to an enhanced component and modifier name, returns the enhanced component augmented with a generated displayName.
Parameters
Function
: Function mapping component to enhanced component.string
: Seed name from which to generated display name.Returns
WPComponent
: Component class with generated display name assigned.# ifCondition
Higher-order component creator, creating a new component which renders if the given condition is satisfied or with the given optional prop name.
Parameters
Function
: Function to test condition.Returns
Function
: Higher-order component.# pure
Given a component returns the enhanced component augmented with a component only rerendering when its props/state change
Parameters
Function
: Function mapping component to enhanced component.string
: Seed name from which to generated display name.Returns
WPComponent
: Component class with generated display name assigned.# useAsyncList
React hook returns an array which items get asynchronously appended from a source array. This behavior is useful if we want to render a list of items asynchronously for performance reasons.
Parameters
Array
: Source array.Returns
Array
: Async array.# useConstrainedTabbing
In Dialogs/modals, the tabbing must be constrained to the content of the wrapper element. This hook adds the behavior to the returned ref.
Usage
import { useConstrainedTabbing } from '@wordpress/compose';
const ConstrainedTabbingExample = () => {
const constrainedTabbingRef = useConstrainedTabbing()
return (
<div ref={ constrainedTabbingRef }>
<Button />
<Button />
</div>
);
}
Returns
Object|Function
: Element Ref.# useCopyOnClick
Deprecated
Copies the text to the clipboard when the element is clicked.
Parameters
Object
: Reference with the element.string|Function
: The text to copy.number
: Optional timeout to reset the returned state. 4 seconds by default.Returns
boolean
: Whether or not the text has been copied. Resets after the timeout.# useCopyToClipboard
Copies the given text to the clipboard when the element is clicked.
Parameters
text|Function
: The text to copy. Use a function if not already available and expensive to compute.Function
: Called when to text is copied.Returns
RefObject
: A ref to assign to the target element.# useDebounce
Debounces a function with Lodash's debounce
. A new debounced function will
be returned and any scheduled calls cancelled if any of the arguments change,
including the function to debounce, so please wrap functions created on
render in components in useCallback
.
Parameters
...any
: Arguments passed to Lodash's debounce
.Returns
Function
: Debounced function.# useFocusOnMount
Hook used to focus the first tabbable element on mount.
Usage
import { useFocusOnMount } from '@wordpress/compose';
const WithFocusOnMount = () => {
const ref = useFocusOnMount()
return (
<div ref={ ref }>
<Button />
<Button />
</div>
);
}
Parameters
boolean|string
: Focus on mount mode.Returns
Function
: Ref callback.# useFocusReturn
When opening modals/sidebars/dialogs, the focus must move to the opened area and return to the previously focused element when closed. The current hook implements the returning behavior.
Usage
import { useFocusReturn } from '@wordpress/compose';
const WithFocusReturn = () => {
const ref = useFocusReturn()
return (
<div ref={ ref }>
<Button />
<Button />
</div>
);
}
Parameters
Function?
: Overrides the default return behavior.Returns
Function
: Element Ref.# useInstanceId
Provides a unique instance ID.
Parameters
Object
: Object reference to create an id for.string
: Prefix for the unique id.string
: Default ID to use.Returns
string | number
: The unique instance id.# useIsomorphicLayoutEffect
Preferred over direct usage of useLayoutEffect
when supporting
server rendered components (SSR) because currently React
throws a warning when using useLayoutEffect in that environment.
# useKeyboardShortcut
Attach a keyboard shortcut handler.
Parameters
string[]|string
: Keyboard Shortcuts.Function
: Shortcut callback.WPKeyboardShortcutConfig
: Shortcut options.# useMediaQuery
Runs a media query and returns its value when it changes.
Parameters
[string]
: Media Query.Returns
boolean
: return value of the media query.# useMergeRefs
Merges refs into one ref callback. Ensures the merged ref callbacks are only
called when it changes (as a result of a useCallback
dependency update) or
when the ref value changes. If you don't wish a ref callback to be called on
every render, wrap it with useCallback( ref, [] )
.
Dependencies can be added, but when a dependency changes, the old ref
callback will be called with null
and the new ref callback will be called
with the same node.
Parameters
Array<RefObject|RefCallback>
: The refs to be merged.Returns
RefCallback
: The merged ref callback.# usePrevious
Use something's value from the previous render. Based on https://usehooks.com/usePrevious/.
Parameters
T
: The value to track.Returns
T|undefined
: The value from the previous render.# useReducedMotion
Hook returning whether the user has a preference for reduced motion.
Returns
boolean
: Reduced motion preference value.# useRefEffect
Effect-like ref callback. Just like with useEffect
, this allows you to
return a cleanup function to be run if the ref changes or one of the
dependencies changes. The ref is provided as an argument to the callback
functions. The main difference between this and useEffect
is that
the useEffect
callback is not called when the ref changes, but this is.
Pass the returned ref callback as the component's ref and merge multiple refs
with useMergeRefs
.
It's worth noting that if the dependencies array is empty, there's not strictly a need to clean up event handlers for example, because the node is to be removed. It is necessary if you add dependencies because the ref callback will be called multiple times for the same node.
Parameters
Function
: Callback with ref as argument.Array
: Dependencies of the callback.Returns
Function
: Ref callback.# useResizeObserver
Hook which allows to listen the resize event of any target element when it changes sizes.
Note: useResizeObserver
will report null
until after first render
Usage
const App = () => {
const [ resizeListener, sizes ] = useResizeObserver();
return (
<div>
{ resizeListener }
Your content here
</div>
);
};
Returns
Array
: An array of {Element} resizeListener
and {?Object} sizes
with properties width
and height
# useThrottle
Throttles a function with Lodash's throttle
. A new throttled function will
be returned and any scheduled calls cancelled if any of the arguments change,
including the function to throttle, so please wrap functions created on
render in components in useCallback
.
Parameters
...any
: Arguments passed to Lodash's throttle
.Returns
Function
: Throttled function.# useViewportMatch
Returns true if the viewport matches the given query, or false otherwise.
Usage
useViewportMatch( 'huge', '<' );
useViewportMatch( 'medium' );
Parameters
WPBreakpoint
: Breakpoint size name.[WPViewportOperator]
: Viewport operator.Returns
boolean
: Whether viewport matches query.# useWarnOnChange
Hook that performs a shallow comparison between the preview value of an object and the new one, if there's a difference, it prints it to the console. this is useful in performance related work, to check why a component re-renders.
Usage
function MyComponent(props) {
useWarnOnChange(props);
return "Something";
}
Parameters
Object
: Object which changes to compare.string
: Just a prefix to show when console logging.# withGlobalEvents
Deprecated
Higher-order component creator which, given an object of DOM event types and values corresponding to a callback function name on the component, will create or update a window event handler to invoke the callback when an event occurs. On behalf of the consuming developer, the higher-order component manages unbinding when the component unmounts, and binding at most a single event handler for the entire application.
Parameters
Object<string,string>
: Object with keys of DOM event type, the value a name of the function on the original component's instance which handles the event.Returns
Function
: Higher-order component.# withInstanceId
A Higher Order Component used to be provide a unique instance ID by component.
Parameters
WPComponent
: The wrapped component.Returns
WPComponent
: Component with an instanceId prop.# withSafeTimeout
A higher-order component used to provide and manage delayed function calls that ought to be bound to a component's lifecycle.
Parameters
WPComponent
: Component requiring setTimeoutReturns
WPComponent
: Wrapped component.# withState
A Higher Order Component used to provide and manage internal component state via props.
Parameters
?Object
: Optional initial state of the component.Returns
WPComponent
: Wrapped component.FAQs
WordPress higher-order components (HOCs).
The npm package @wordpress/compose receives a total of 112,476 weekly downloads. As such, @wordpress/compose popularity was classified as popular.
We found that @wordpress/compose demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.